1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
use crate::co;
use crate::decl::*;
use crate::gui::{*, iterators::*, privs::*, spec::*};
use crate::msg::*;
use crate::prelude::*;
/// Exposes column methods of a [`ListView`](crate::gui::ListView) control.
///
/// You cannot directly instantiate this object, it is created internally by the
/// control.
pub struct ListViewColumns<'a, T: 'static> {
owner: &'a ListView<T>,
}
impl<'a, T> ListViewColumns<'a, T> {
#[must_use]
pub(in crate::gui) const fn new(owner: &'a ListView<T>) -> Self {
Self { owner }
}
/// Adds many columns at once by sending an
/// [`lvm::InsertColumn`](crate::msg::lvm::InsertColumn) message.
///
/// Widths will be adjusted to match current system DPI.
///
/// # Examples
///
/// ```no_run
/// use winsafe::{self as w, prelude::*, gui};
///
/// let my_list: gui::ListView; // initialized somewhere
/// # let wnd = gui::WindowMain::new(gui::WindowMainOpts::default());
/// # let my_list = gui::ListView::<()>::new(&wnd, gui::ListViewOpts::default());
///
/// my_list.columns().add(&[
/// ("Name", 300),
/// ("Address", 500),
/// ]);
/// ```
pub fn add(&self, texts_and_widths: &[(impl AsRef<str>, u32)]) {
for (text, width) in texts_and_widths.iter() {
let mut col_cx = SIZE::new(*width as _, 0);
multiply_dpi(None, Some(&mut col_cx)).unwrap();
let mut lvc = LVCOLUMN::default();
lvc.mask = co::LVCF::TEXT | co::LVCF::WIDTH;
lvc.cx = col_cx.cx;
let mut wtext = WString::from_str(text.as_ref());
lvc.set_pszText(Some(&mut wtext));
unsafe {
self.owner.hwnd()
.SendMessage(lvm::InsertColumn {
index: 0xffff, // insert as the last columns
column: &lvc,
})
}.unwrap();
}
}
/// Retrieves the number of columns by sending an
/// [`hdm::GetItemCount`](crate::msg::hdm::GetItemCount) message to the
/// handle returned by [`lvm::GetHeader`](crate::msg::lvm::GetHeader).
#[must_use]
pub fn count(&self) -> u32 {
unsafe {
self.owner.hwnd()
.SendMessage(lvm::GetHeader {})
.unwrap()
.SendMessage(hdm::GetItemCount {})
.unwrap()
}
}
/// Retrieves the column at the given zero-based position.
///
/// **Note:** This method is cheap – even if `index` is beyond the range of
/// existing columns, an object will still be returned. However, operations
/// upon this object will produce no effect.
#[must_use]
pub const fn get(&self, index: u32) -> ListViewColumn<'a, T> {
ListViewColumn::new(self.owner, index)
}
/// Returns an iterator over all columns.
#[must_use]
pub fn iter(&self) -> impl Iterator<Item = ListViewColumn<'a, T>> + 'a {
ListViewColumnIter::new(self.owner)
}
}